Java 中 this 和 super 的用法总结
全部标签 我一直在测试以下代码,但Firefox16和Chrome22给出了不同的结果。console.log(this===window);//falseinFirefoxandtrueinChromeconsole.log(this.window===window);//trueinbothFirefoxandChrome(function(){console.log(this===window);//falseinFirefoxandtrueinChromeconsole.log(this.window===window);//trueinbothFirefoxandChrome})();
拜托,有人能告诉我this.init.apply(this,arguments)在下面的代码中做了什么吗?我理解apply()的一般作用,但在下面代码的上下文中,它在做什么?varClass=function(){varklass=function(){this.init.apply(this,arguments);//Idon'treallygetthisbit...};klass.prototype.init=function(){};returnklass;};varPerson=newClass;//Usagevarsomeone=newPerson;我看到很多人都在使用它。我
在使用$.extend扩展对象时有没有办法访问super对象?我想扩展一个对象,覆盖一个方法,但是在子类方法中调用被覆盖的父类(superclass)方法。 最佳答案 不,因为没有父类(superclass)。根据jQuery.extend的文档:Description:Mergethecontentsoftwoormoreobjectstogetherintothefirstobject.为了调用“父类(superclass)”方法,您必须在某处保留“父类(superclass)”的副本(可能作为“后代”对象中的参数),并直接在“
出于好奇,有没有办法从paint函数访问this.color?functionFoo(color){this.color=color;this.paint=functionpaint(){$("select").each(function(idx,el){$(el).css("background",color);//OK//$(el).css("background",this.color);//this.colorisundefined})}}newFoo("red").paint();谢谢 最佳答案 varthat=this;
我需要一个Set,其API类似于Java中的Set。这个实现:http://jsclass.jcoglan.com/set.html需要用到RequireJS,这下需要我的Java脑子绞尽脑汁了。发布一个作为Set功能的函数将是一个很好的答案。或已创建此代码的GoogleSet或其他科技巨头的链接。谷歌倒闭了怎么办?这个名字让我感到困惑,但它有一套。 最佳答案 在我看来,无论java.util.Set可以实现什么,都可以使用简单的javascript对象来完成。我不明白你为什么需要额外的库://emptysetvarbasket={
我想认为我了解JavaScript,但我今天发现了一些意想不到的事情,我希望有人能向我解释为什么会这样。拿这个代码varanimalData={cow:"cow",sheep:"sheep",getCow:function(){returnthis.cow;},animalList:[{animalId:this.cow,label:"Thisisacow"},{animalId:this.sheep,label:"Thisisasheep"}]};console.log(animalData.getCow());console.log(JSON.stringify(animalDat
如果我打开一个空白页面并在javascript控制台中运行以下命令,我会得到相同的结果:>>>thisDOMWindow>>>selfDOMWindow>>>windowDOMWindow>>>window.selfDOMWindow它们指的是什么?...相同的对象还是其他什么? 最佳答案 window是对脚本执行所在的当前浏览器窗口的引用。window.self显然是其自身的自引用。因为这里的self是全局对象window的一个属性,它也可以被访问,就像它本身就是一个“全局”变量一样:只是self.所以最后三个在大多数情况下确实是
根据返回的this,第1-2行和第4-5行是有意义的。关于第3行,我缺少什么?我认为它会返回类似于第4-5行的window。在这5个中是否还有其他模式可以帮助证明原因?foo={bar:function(){returnthis}}foo.bar()//==>foo(foo.bar)()//==>foo/butwhy?(foo.bar?foo.bar:$.noop)()//==>window(foo.bar||0)()//==>window 最佳答案 分组运算符不会破坏引发方法调用的属性引用。thespec中明确提到了这一点:NOT
我目前正在开发一个React应用程序,我发现当一个组件类有很多功能时必须绑定(bind)this有点麻烦。例子classFooextendsComponent{constructor(props){super(props);this.function1=this.function1.bind(this);this.function2=this.function2.bind(this);this.function3=this.function3.bind(this);}function1(){...}function2(){...}function3(){...}}有没有更有效的方法来做
看完相关问题#1,#2我仍然没有找到以下问题的答案:Javascript可以通过以下方式设置上下文(即设置this):bind、call和apply。但是当我编写事件处理程序时:document.getElementById('myInput').onclick=function(){alert(this.value)}谁/什么实际上附加this到对象本身?附言使用jQuery时:$("#myInput").bind(function(){...})是(bind、call或apply)的内部实现所以当我不使用jQuery时,谁在使用它? 最佳答案